import { ListViewBase } from '../../../view/listview-base';
import { AppLayoutService } from '../../../app-service/common-service/app-layout-service';

/**
 * 应用列表视图基类
 *
 * @export
 * @class AppListViewBase
 * @extends {ListViewBase}
 */
export class AppListViewBase extends ListViewBase {
  /**
   * 列表视图渲染
   *
   * @memberof AppListViewBase
   */
  render(h: any) {
    if (!this.viewIsLoaded) {
      return null;
    }
    const targetViewLayoutComponent: any = AppLayoutService.getLayoutComponent(`${this.viewInstance?.viewType}-${this.viewInstance?.viewStyle}`);
    return h(
      targetViewLayoutComponent,
      {
        props: { viewInstance: this.viewInstance, model: this.model, modelService: this.modelService, viewparams: this.viewparams, context: this.context },
      },
      [
        this.renderTopMessage(),
        this.renderToolBar(),
        this.renderQuickGroup(),
        this.renderQuickSearch(),
        !(this.viewInstance?.viewStyle == 'DEFAULT' && this.viewInstance?.enableQuickSearch) ? [this.renderSearchForm(), this.renderSearchBar()] : null,
        this.renderBodyMessage(),
        this.renderMainContent(),
        this.renderBottomMessage(),
      ],
    );
  }
}
